CLAIMS 



1 1. A method in a computer system for importing data into a data 

2 store, the method comprising: 

3 for each of a plurality of types of import sources, defining import 

4 metadata that specifies how the import data of that type of import source is to be 

5 imported into the data store; 

6 receiving import data to be imported into the data store, the import 

7 data including an indication of a type of import source; 

8 retrieving the metadata defined for the type of import source; and 

9 importing the import data into data store in accordance with the 
io retrieved metadata. 

1 2. The method of claim 1 wherein the metadata for a type of 

2 import source specifies a schema for a portion of the data store into which the 

3 import data of that type is to be imported. 

1 3. The method of claim 1 wherein the metadata for a type of 

2 import source specifies dimension and fact tables of the data store into which the 

3 import data of that type is to be imported. 

1 4. The method of claim 3 wherein the dimension and facts tables 

2 are dynamically created when importing data. 

1 5. The method of claim 1 wherein a type of import source 

2 represents companies in a similar market. 
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1 6. The method of claim 1 wherein each import source is a 

2 different company. 

1 7. The method of claim 1 wherein each import source represents 

2 organizations that generate similar types of data. 



1 8. The method of claim 1 including modifying the metadata for a 

2 type of import source so that, when import data of that type of import source is next 

3 imported, it is imported in accordance with the modified metadata. 

1 9. A computer-readable medium containing a data structure 

2 having metadata relating to importing import data into a data store, the data 

3 structure comprising: 

4 for each table into which import data is to be imported, 

5 an indication of a table name; and 

6 for each property to be included as a column of the table, 

7 an indication of a name of the property; 

8 an indication of a field of the import data; and 

9 an indication of how a value for the property of the table 
io is to be calculated from the indicated field of the import data. 

1 10. The computer-readable medium of claim 9 containing different 

2 indications for each type of import source of import data. 

1 11. The computer-readable medium of claim 9 wherein the 

2 indications are used to dynamically generate tables of the data store when import 

3 data is imported. 
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1 12. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each table an indication as to whether a parent table in 

3 the data store is to be updated based on import data. 

1 13. The computer-readable medium of claim 12 wherein when a 

2 parent table is to be update the data structure includes an indication of how the 

3 parent table is to be updated. 

1 14. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each table an indication as to whether an additional 

3 column is to be added to the table to reflect visit information. 

1 15. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each property an indication of whether a lookup table 

3 should be generated for the import data of that property. 

1 16. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each property an indication of whether the import data 

3 for that property should be grouped into buckets. 

1 17. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each property an indication of whether the import data 

3 for that property should be included in a hash value. 

1 18. The computer-readable medium of claim 9 wherein the data 

2 structure further includes for each property an indication of whether the import data 

3 for that property should be included in a key. 
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19. A method in a computer system for importing import data into 
a data store, the method comprising: 

providing metadata that defines a schema for the data store and 
defines how the import data is to be stored in the data store; 

receiving import data to be stored in the data store; 

after receiving the import data, generating the data store in accordance 
with the schema defined by the provided metadata; and 

storing data into the generated data store in accordance with how the 
import data is to be stored in the data store as indicated by the provided metadata. 

20. The method of claim 19 wherein the schema specifies fact and 
dimension tables to be included in the data store. 



2 1 . The method of claim 1 9 including providing modified metadata 
with a modified schema wherein when import data is subsequently received the 
generated data store is modified in accordance with the modified schema. 



22. The method of claim 19 including providing metadata for a 
plurality of different types of import sources wherein import data is imported in 
accordance with the metadata for the type of import source of the import data. 

23. The method of claim 19 wherein the metadata includes an 
indication of a name of each table of the data store. 



24. The method of claim 23 wherein the metadata includes for each 
table of the data store an indication of each property of the table. 
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25. The method of claim 24 wherein the metadata includes an 
attribute for each property indicating whether a lookup table should be generated for 
that property when import data is imported. 

26. The method of claim 24 wherein the metadata includes an 
attribute for each property indicating whether that property should be included in a 
hash value. 

27. The method of claim 24 wherein the metadata includes an 
attribute for each property indicating whether that property should be included in a 

key. 

28. The method of claim 24 wherein the metadata includes an 
attribute for each property indicating whether a value for that property should be 
derived from a related dimension table. 

29. The method of claim 24 wherein the metadata includes an 
attribute for each property indicating whether the import data for that property 
should be grouped into buckets. 

30. A method in a computer system for transforming data stored in 
a data store, the method comprising: 

providing metadata that defines a schema for a transformed data store 
and defines how the data in the data store is to be transformed; 

generating the transformed data store in accordance with the schema 
defined by the provided metadata; and 

storing data into the generated transformed data store in accordance 
with how the data in the data store is to be transformed and stored in the 
transformed data store as indicated by the provided metadata. 
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31. The method of claim 30 wherein the schema specifies fact and 
dimension tables to be included in the transformed data store. 

32. The method of claim 30 wherein the metadata includes an 
indication of a name of each table of the transformed data store. 

33 . The method of claim 30 wherein the metadata includes for each 
table of the transformed data store an indication of each property of the table. 

34. The method of claim 33 wherein the metadata includes an 
attribute for each property indicating whether that property should be included in a 
hash value. 

35. The method of claim 33 wherein the metadata includes an 
attribute for each property indicating whether that property should be included in a 
key. 

36. A method in a computer system for aggregating data of a data 
store, the method comprising: 

for each of a plurality of different aggregations of the data store, 
providing metadata that defines the aggregation, the metadata including an 
indication of an aggregating property of a dimension table of the data store and one 
or more measures to be included the aggregation, each measure being derived from 
a fact table of the data store; 

receiving an indication to aggregate the data of the data store in 
accordance with an aggregation; 

retrieving the provided metadata for that aggregation; and 

aggregating the data of the data store in accordance with the retrieved 

metadata. 
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37. The method of claim 36 wherein the metadata includes an 
aggregation function for each measure of the aggregation, the aggregation function 
indicating how to aggregate the data of the data store for that measure. 

38. The method of claim 36 wherein the data is aggregated into a 
table with one column for the aggregating property and for each measure indicated 
by the provided metadata. 

39. A method in a computer system for storing data generated by a 
plurality of web sites in a data store, the method comprising: 

providing for each web site, metadata that defines structure of the 
tables of the data store into which the data of that web site is to be stored and 
defines how the data of the web site is to be stored in the tables; 

receiving data from each of the plurality of web sites; and 
for each web site from which data is received, 

retrieving the metadata provided for that web site; 
creating tables of the data store in accordance with the 
retrieved metadata; and 

storing data in the created tables in accordance with the 
retrieved metadata and the received data. 

40. The method of claim 39 wherein the received data includes 
indications of events identified by parsing click stream data generated for the web 
site. 

41. The method of claim 39 wherein the received data includes 
information on items available to be purchased via the web site. 
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42. The method of claim 39 wherein the received data includes 
information relating to users of the web site. 

43. The method of claim 39 wherein the stored data for a web site 
is accessible by a representative of the web site through a hosted service provider. 

44. A method in a computer system for storing data generated by a 
plurality of web sites in a data store, the method comprising: 

providing for each web site, metadata that defines structure of the 
tables of the data store into which the data of that web site is to be stored and 
defines how the data of the web site is to be stored in the tables; 

receiving data from each of the plurality of web sites, the data 
including click stream data and non-click stream data; and 
for each web site from which data is received, 

retrieving the metadata provided for that web site; 
creating tables of the data store in accordance with the 
retrieved metadata; and 

storing data in the created tables in accordance with the 
retrieved metadata and the received data wherein the click stream data is correlated 
with non-click stream data. 

45. The method of claim 44 wherein the received data includes 
indications of events identified by parsing click stream data generated for the web 
site. 

46. The method of claim 44 wherein the non-click stream data 
includes information on items available to be purchased via the web site. 
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47. The method of claim 44 wherein the non-click stream data 
includes information relating to users of the web site. 

48. The method of claim 44 wherein the stored data for a web site 
is accessible by a representative of the web site through a host service provider. 

49. A computer-readable medium containing instructions for 
controlling a computer system to import data, by a method comprising: 

providing import metadata that specifies how import data for a 
plurality of types of import sources is to be imported; 

receiving import data to be imported, the import data having an 
indication of a type of import source; 

retrieving the metadata defined for the indicated type of import 

source; and 

importing the import data in accordance with the retrieved metadata. 

50. The computer-readable medium of claim 49 wherein the 
metadata for a type of import source specifies a schema for a portion of a data store 
into which the import data of that type is to be imported. 

51. The computer-readable medium of claim 49 wherein the 
metadata for a type of import source specifies dimension and fact tables of a data 
store into which the import data of that type is to be imported. 

52. The computer-readable medium of claim 51 wherein the 
dimension and facts tables are dynamically created when importing data. 

53. The computer-readable medium of claim 49 wherein a type of 
import source represents companies in a similar market. 
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54. The computer-readable medium of claim 49 wherein each 
import source is a different company. 

55. The computer-readable medium of claim 49 wherein each 
import source represents organizations that generate similar types of data. 

56. The computer-readable medium of claim 49 including 
modifying the metadata for a type of import source so that, when import data of that 
type of import source is next imported, it is imported in accordance with the 
modified metadata. 

57. A computer system for importing import data into a data store, 

comprising: 

a metadata store containing metadata that defines a schema for the 
data store and defines how import data is to be stored in the data store; 

an import data store containing import data to be stored in the data 

store; 

a data store generating component that generates the data store in 
accordance with the schema defined by the metadata in the metadata store; and 

a storing component that stores data into the generated data store in 
accordance with how the import data is to be stored in the data store as indicated by 
the metadata in the metadata store. 

58. The computer system of claim 57 wherein the schema specifies 
fact and dimension tables to be included in the data store. 

59. The computer system of claim 57 wherein the metadata store 
includes modified metadata with a modified schema wherein when import data is 
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3 subsequently imported the generated data store is modified in accordance with the 

4 modified schema. 



1 60. The computer system of claim 57 wherein metadata for a 

2 plurality of different types of import sources is provided and wherein import data is 

3 imported in accordance with the metadata for the type of import source of the 

4 import data. 

1 61. The computer system of claim 57 wherein the metadata 

2 includes an indication of a name of each table of the data store. 

1 62. The computer system of claim 61 wherein the metadata 

2 includes for each table of the data store an indication of each property of the table. 

1 63. The computer system of claim 62 wherein the metadata 

2 includes an attribute for each property indicating whether a lookup table should be 

3 generated for that property when import data is imported. 

1 64. The computer system of claim 62 wherein the metadata 

2 includes an attribute for each property indicating whether that property should be 

3 included in a hash value. 

1 65. The computer system of claim 62 wherein the metadata 

2 includes an attribute for each property indicating whether that property should be 

3 includes in a key. 

1 66. The computer system of claim 62 wherein the metadata 

2 includes an attribute for each property indicating whether a value for that property 

3 should be derived from a related dimension table. 
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67. The computer system of claim 62 wherein the metadata 
includes an attribute for each property indicating whether the import data for that 
property should be grouped into buckets. 

68. A computer-readable medium containing instructions for 
controlling a computer system to aggregate data, by a method comprising: 

providing metadata that defines the aggregation, the metadata 
including an indication of an aggregating property of a dimension table and one or 
more measures to be included the aggregation, each measure being derived from a 
fact table; and 

aggregating the data in accordance with the provided metadata. 

69. The computer-readable medium of claim 68 wherein the 
metadata includes an aggregation function for each measure of the aggregation, the 
aggregation function indicating how to aggregate the data of the data store for that 
measure. 

70. The computer-readable medium of claim 68 wherein the data is 
aggregated into a table with one column for the aggregating property and for each 
measure indicated by the provided metadata. 

71. A computer system for storing data generated by a plurality of 
web sites in a data store, comprising: 

metadata storage means for storing metadata that defines structure of 
tables of the data store into which the data of a web site is to be stored and that 
defines how the data of the web site is to be stored in the tables; 

data storage means for storing data for each of the plurality of web 

sites; and 
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8 means for retrieving the metadata for a web site, for creating tables of 

9 the data store in accordance with the retrieved metadata, and for storing data in the 
10 created tables in accordance with the retrieved metadata and the data of the data 
n storage means. 

1 72. The computer system of claim 71 wherein the data in the data 

2 storage means includes indications of events identified by parsing click stream data 

3 generated for the web site. 

1 73. The computer system of claim 71 wherein the data in the data 

2 storage means includes information on items available to be purchased via the web 

3 site. 

1 74. The computer system of claim 71 wherein the data in the data 

2 storage means includes information relating to users of the web site. 

1 75. The computer system of claim 7 1 wherein the stored data in the 

2 created tables for a web site is accessible by a representative of the web site through 

3 a host service provider. 

4 76. The method of claim 1 wherein the metadata optionally 

5 specifies a subset of fields of the input data that is to be imported. 
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